# Simulation and DSP Implementation of ADSL Modem Using C6713 Processor

Hossam Labib A. Zayed<sup>1</sup>, Abdel Halem A. Zekry<sup>2</sup>, Adel Ezzat Elhennawy<sup>3</sup>, and Ayman M. Hassan<sup>4</sup>

Abstract—In this paper, simulation and implementation of Asymmetric Digital Subscriber Line (ADSL) modem is presented which can be applied to different telephone networks. The ADSL modem is modeled and simulated under the MATLAB version 7.3 (R2006b) environments by which the simulation is achieved for both the downstream and upstream directions of the modem. The ADSL modem with a transmission throughput between 640 kbps and 6 Mbps operating over most of existing telephone subscriber loops has been implemented on TI TMS320C6713 DSP for consumer multimedia applications. Except the Analog Front End, all the basic building blocks of the ADSL modem functionalities are implemented with DSP platform. We use Real-Time Data Exchange (RTDX) as a way to debug and test our DSP designs.

Index Terms—ADSL, DMT, RTDX, TMS320C6713

## I. INTRODUCTION

A SYMMETRIC Digital Subscriber Line (ADSL) is a high speed data transmission technology that allows reuse of existing copper phone line [1]. It allows up to 8 Mbps data transmission on downstream and 640 Kbps on upstream [2]. To increase the spectral efficiency of the available bandwidth, ADSL employs a transmission technique based on Multicarrier modulation, namely, discrete multitone (DMT) [3, 4]. ADSL uses two separate frequency bands, the band from 25.875 kHz - 138 kHz is used for upstream communication, while 138 kHz – 1104 kHz is used for downstream communication.

DMT divides the available bandwidth into N parallel subchannels or tones, by means of an N-point inverse fast Fourier transform (IFFT). At the transmitter, each tone is modulated by quadrature amplitude modulation (QAM) and IFFT transformed to obtain a time domain signal. At the receiver, an N-point FFT can be used for demodulation. Prepending each data block after IFFT modulation with a cyclic prefix ensures that the subchannels remain independent after transmission over a channel. If the order of the channel is smaller than the cyclic prefix length, v, the transmitted signal can easily be recovered by the so-called frequency domain equalizers (FEQs). Besides equalization, echo cancellation is required to separate upstream and downstream signals and to enable efficient bidirectional communication over the same telephone wire. Echo cancellation can improve the reach and/or noise margin of an ADSL system by allowing both upstream and downstream signals to share the low frequency portion of the available frequency band.

Daniel [5], proposed and implemented a new link aggregation model for ADSL that operates with any combination of circuit rates, supports dynamic link rate changes, and requires minimal overhead. Liang [6], presented a modified method based on multi-user detection, which can mitigate the crosstalk interference in DMT-ADSL receiver. Miloš [7], proposed an equalizer design that maximizes the bit rate of a DMT system at the output of the FFT demodulator and introduced a novel receiver architecture that uses time domain per-tone equalizer filter bank (TEQFB) that maximizes a measure of the ADSL system bit rate. Ravishankar [8], proposed a new bit-loading algorithm that reduces the power required to transmit data. He simulated and implemented such ADSL system with bit- loading algorithm. Sobia [9], discussed the use of discrete multitone technology at the PHY layer of an in-home power line communication network, particularly with reference to bit-loading techniques.

In this paper, ADSL system is presented and simulated under the MATLAB version 7.3 (R2006b) environments to test the system performance. The proposed system is implemented on TI TMS320C6713 DSP kit. All the basic building blocks of the ADSL modem functionalities are implemented, tested and debugged using Real-Time Data Exchange (RTDX).

### II. ADSL MODEM SIMULATION

Both the downstream and upstream paths that represent the ADSL modem are simulated and tested under different amount of noise using MATLAB version 7.3 (R2006b) environments. Asymmetric data rate is achieved by taking different bandwidth for FFT/IFFT pair in each direction. The design parameters that are used in the simulation are summarized in Table1.

In the ADSL modem simulation, no pilot carriers are used since no synchronization problem is considered and perfect knowledge of the channel transfer function is assumed at the receiver for simplification purposes. Figure 1 shows the overall block diagram for the ADSL transmitter and receiver.

As shown in Figure 1, the binary input data are separated into two parallel paths, the first one (the path at the top of the figure) is called the fast path or the fast buffer, while the other is the interleaved path or buffer. The interleaved path supports a convolutionally interleaved RS error correction. Interleaving operation increases the second path resistance to burst errors, but also it increases its latency. The greater resistance to errors in the interleaved path is meant to support applications that are sensitive to degradation due to errors induced by line noise but

Manuscript received July 31, 2009.

<sup>1,4.</sup> Higher Institute of Technology-Benha University, Benha, Egypt

<sup>2, 3.</sup> Faculty of Engineering-Ain Shams University, Cairo, Egypt.

 <sup>1.</sup>Hossam 1 zayed@hotmail.com,
 2.aaazekry@hotmail.com

 3.a.hennawy@hotmail.com,
 4. ayman mustafa46@yahoo.com

relatively tolerant to increased latency. Moreover, the data in the second path is modulated to the high frequencies subcarriers by which they are vulnerable for attenuation in such high frequencies. The fast path provides less protection against transmission errors but less delay. It is meant to transport delay-sensitive applications such as interactive data.

| v             | I I         |             |
|---------------|-------------|-------------|
| Parameter     | Downstream  | Upstream    |
| Number of     | 256         | 32          |
| subchannels   |             |             |
| FFT/IFFF size | 512 points  | 64 points   |
| Cyclic Prefix | 32 samples  | 4 samples   |
| Length        |             |             |
| Nyquist       | 1.104 MHz   | 138 KHz     |
| Frequency     |             |             |
| Sampling      | 2.208 MHz   | 276 KHz     |
| Frequency     |             |             |
| Subchannel BW | 4.3125 KHz  | 4.3125 KHz  |
| Symbol Time   | 250 µSecond | 250 µSecond |

Table 1 ADSL Simulation Parameters





The sequence of the coding techniques appeared in Figure 1 is arranged as follows: At the beginning, the CRC bits are added in order to flag error detected at the end of the reception, thus detecting errors that are not corrected by the RS code. After the CRC, the scrambler scrambles the data sequence so that problems come with the long string of 0s and 1s are reduced and avoided. After that, the RS code appends certain bits for data correction and attempt to correct the received bits with errors. Finally, the interleaver in the interleaved path has a significant role to reduce burst errors and make the errors within the RS code correctable number of errors.

After the error detection and correction codes as well as scrambling and interleaving, the data are modulated using the DMT modulator, by which the input stream is divided into 256 subchannels in accordance with the 256 carriers of the ADSL specifications for the downstream path, and 32 subchannels for the upstream path. The output signal from the DMT modulator is totally real, because the real part of frequency domain signal has an even symmetry and the imaginary part which in turn has an odd symmetry, and this is due to Hermitian symmetry.

## A. ADSL Transmitter

The transmitter consists of the following functional blocks.

## 1) Input Data Source

The data source is modeled as Bernoulli Binary Generator block that generates random binary numbers with equal probability of zeros and ones. The output data is a frame-based matrix and frame rate is 4000 frame/sec. For the downstream path, the number of bits per frame is equal to 1552 and the sample time is 0.16108  $\mu$ Second with one sample/bit. For the upstream path, the number of bits per frame is equal to 92 and the sample time is 2.71739  $\mu$ Second with one sample/bit.

The transmitter contains two parallel paths. One path (the fast buffer) processes the first 776 bits of each 1552-bit data frame, while the other path (the interleaved buffer) processes the last 776 bits of each data frame. In case of upstream path the fast buffer processes the first 46 bits and the interleaved buffer processes the last 46 bits of each data frame.

## 2) General CRC Generator

The General CRC Generator block generates cyclic redundancy code (CRC) bits for each input data frame and appends them to the frame. Each path (fast or interleaved) appends eight cyclic redundancy check (CRC) bits to its 776bit frame.The uesd generator polynomial is  $G(D) = D^8 + D^4 + D^3 + D^2 + 1$  (1)

The bit stream from the CRC generator is then passed through a self-synchronizing scrambler to break up long strings of 1's and 0's. The connection polynomial is  $P(z^{-1})=1+z^{-18}+z^{-23}$  (2) with zeros for the Initial states of the linear feedback shift registers. The scrambling and encoding operations interpret the bits as integers between 0 and 127.

4) Reed-Solomon (RS) Encoder

Successive blocks of bits from the scrambler are operated on by the Reed-Solomon encoder which adds redundant bits to the blocks so that transmission errors can be corrected at the receiver. This process is often called forward error correction (FEC). RS codes are used in DSL because they provide coding gain against random errors (of about 3dB) [1].

The Integer-Input RS Encoder block creates a Reed-Solomon code with message length K and codeword length N. An (N, K) Reed-Solomon code can correct up to floor ((N-K)/2) symbol errors (not bit errors) in each codeword. The input and output are integer-valued signals that represent messages and codewords, respectively. The input must be a frame-based column vector whose length is an integer multiple of K. The output is a frame-based column vector whose length is the same integer multiple of N, and whose data type is inherited from the input [10].

RS code is based on a finite field called the Galois Field (GF). For the ADSL modem design, all arithmetic in the RS codes are byte-wise in the finite field GF256 (GF $(2^8)$ ), that means every symbol in an RS code for ADSL is a byte (8 bits).

In our block we used RS (120,112) code with error correcting capability of 4 bytes/symbol. In case of upstream path we used RS (15, 9) code with error correcting capability of 3 bytes/symbol.

*5) Convolutional Interleaver* 

In the second path a convolution interleaver block interleaves the encoding data. This interleaving operation

increases the second path resistance to burst errors but also its latency.

An impulse noise can corrupt several multi-carrier symbols and cause bursts of errors in the received data streams if no special precautions are taken. ADSL systems protect against bursts in two ways. First, the Reed-Solomon codes discussed in the previous section naturally can correct multiple bit errors in a single code symbol, which consist of a string of eight bits, since any pattern of eight or less bits is treated as a single code symbol error. Second, a technique called interleaving is required by the standards for the data streams needing low error rates [11].

In the simulated ADSL modem, a convolutional interleaver is used. The Convolutional Interleaver block permutes the symbols in the input signal. Internally, it uses a set of shift registers. The delay value of the kth shift register is (k-1) times the Register length step parameter. The number of shift registers is the value of the Rows of shift registers parameter.

For both the downstream and upstream paths, the interleaving depth that is used in the simulation is equal to 2 and the number of shift registers is equal to 5. So this causes a delay equal to 40 samples.

The data from the two paths (fast and interleaved) is concatenated to create contiguous output signal.

6) Discret Multitone (DMT) Modulator

The DMT block diagram that is used in the ADSL modem simulation is shown in Figure 3. The DMT signaling technique divides the channel into 256 subchannels and modulates each one individually. Each of the 16 Modulator Bank icons represents a set of 16 Rectangular QAM Modulator Baseband blocks The DMT technique allocates different numbers of bits to different subchannels. Each copy of the modulator block acts as a distinct subchannel, and uses the 256-element bit allocations to determine the M-ary number parameter that is appropriate for that subchannel. The system has 256 modulator blocks in total in case of downstream path and 32 modulator blocks in total in case of upstream path.

After concatenating the coded data bits, these bits are then assigned to each of the N/2 = 256 subchannels using a bit loading algorithm called water-filling algorithm [12,13]. In the simulated modem, a specific bit loading distribution is used by which the number of bits/subchannel is varied from 1 up to 12 bits. The second step in DMT modulation is the mapping of the assigned bits to subsymbols using variable-size QAM constellation. QAM is used to map the input bit stream into complex values in frequency domain samples. To obtain time domain real samples we use IFFT. The array of (N/2)=256 complex values with their conjugate symmetric one should enter the IFFT block to generate N=512 real time domain samples. The obtained time domain samples are called a DMT symbol. For the downstream path of the presented modem, the IFFT size is 512 point, and for the upstream path, 64 point IFFT is used.

Each DMT symbol is prepended by (1/16) of the symbol itself called cyclic prefix to eliminate Intersymbol Interference (ISI). After the FFT in the receiver, the subsymbols are the product of the N-point FFT of the channel impulse response and the N-point FFT of the transmitted subsymbols [14]. For the downstream path of the ADSL modem, CP is realized by copying the last 32 samples from the 512 samples of the DMT symbol and appending them to the beginning of this DMT

symbol. And for the upstream path, the last 4 samples are copied and appended to the beginning of the DMT symbol that consists from 64 samples.



Figure 2. DMT Modulator.

# B. The Telephone Channel

The telephone line is modeled as a Finite Impulse Response (FIR) filter of length 101 and the Additive White Gaussian Noise (AWGN) channel as a source of the noise. For simplicity, the modeled channel that is used in the ADSL system is considered as an equalized channel, i.e. its impulse response is assumed to be equalized by a TEQ. The frequency and phase response of the channel are shown in figure 3, 4 respectively.



Figure 4. The Phase Response of the Channel.

## C. ADSL Receiver

The receiver attempts to undo each operation that the transmitter performs and eventually generates the original data bit stream after demodulation and decoding processes. For example, to undo the actions of the Convolutional Interleaver block, use a Convolutional Deinterleaver block with the same mask parameters.

## III. SIMULATION RESULTS

The frequency spectrum for the transmitted data at the transmitter side of the downstream path and the upstream path of the ADSL modem are plotted as shown in figure 5, 6 respectively. The simulation results of BER shown in figure 7 show the interleved path will have lower BER than the noninterleaved one.



Figure 5. The Frequency Spectrum for Transmitted data at Downstream path.



Figure 6. The Frequency Spectrum for Transmitted data at Upstream path.

## IV. HARDWARE IMPLEMENTATION

The C6713 is considered to be one of the Texas Instruments<sup>TM</sup> most powerful processors; but it's practical application are greatly minimized if it is not made to operate in the standalone state [15], the CPU is based on very long instruction word (VLWI) architecture. This processor has eight functional units that works in parallel, six arithmetic logic units (ALUs) and two multiplier units with whom a total of eight 32-bit instructions can be fetched every clock cycles, also it contains 264 kB of internal memory and two sets of 32-

bit general purpose registers. The CPU operates at 225MHz delivering a peak performance of 1.35 giga-floating-point operations per second (GFLOPS) and 450 million multiply accumulate cycles per second (MMACS)[16,17,18]. The DSK connects to a host PC via a USB port. The TMS320C6713 DSK board includes:

• 32- bit stereo codec TLV320AIC23 with two inputs and two outputs, variable sampling rates from 8 to 96 KHz.

• 16 MB of synchronous dynamic random access memory (SDRAM).

- 256 kB of flash memory.
- Four light-emitting diodes (LEDs) and four dip switches.

• External memory interface (EMIF).

Finally it comes with a powerful PC software in the form of Code Composer Studio (CCS) is provided in order to enable software written in C or assembly language to be compiled and/or assembled, linked, and downloaded to run on the DSK [19].



The Embedded Target for TI C6000 DSP provides the Application Programming Interface (APIs) required by real time workshop to generate a code specifically for the C6000 platform. MATLAB Simulink uses a block based approach implementation instead of complex algorithm design. Link for Code Composer Studio is used to invoke the code building process. This code can then be downloaded on the target from where it runs. The data on the target is accessible in CCS or in MATLAB via link for CCS or via Real-Time Data Exchange (RTDX).

Link for RTDX Interface provides a communications pathway between MATLAB and digital signal processors installed on the PC. Using objects in the MATLAB Link for Code Composer Studio, you open channels to processors on boards in your computer and send and retrieve data about the processors and executing applications, as well as send data to the processes for use and get data from the applications.

The general structure of the implemented ADSL transmitter and receiver system is depicted in Figure 1. We converted the simulated ADSL system model into implemented model to be implemented on the DSP kit. The system level design was made using Matlab version 7.3 and Code Composer Studio 3.1. The implementation is done

through cooperation for direct code generation from the MATLAB and execution at the TMS320C6713 DSK development kit using CCS3.1. The output of the transmitter and receiver (non-interleaved path and interleaved path) are taked and displayed by four RTDX output channels named Tx\_Non\_Int\_out, Rx\_Non\_Int\_out, Tx Int out and Rx Int out respectively. The RTDX output channels for noninterleaved path and interleaved path are shown in figure 8. As shown in figure 8 the output data bits of the received channel Rx\_Non\_Int\_out is the same as the transmitted channel Tx\_Non\_Int\_out but in the case of interleaved path there are 7 bits delay between the received channel Rx\_Int\_out and the transmitted channel Tx Int out. The corresponding delay is due to latency of the interleaved path.

|    | Tx_Non_Int_ |              | Rx_Non_Int_ | Tx_Int_out | Rx_Int_out | I   |
|----|-------------|--------------|-------------|------------|------------|-----|
| 1  | 0           |              | 0           | 0          | 0          | I   |
| 2  | 0           |              | 0           | 0          | 1          | I   |
| 3  | 0           |              | 0           | 1          | 1          | I   |
| 4  | 1           |              | 1           | 1          | 0          | L   |
| 5  | 1           |              | 1           | 1          | 0          | l   |
| 6  | 1           |              | 1           | 1          | 1          | II. |
| 7  | 1           |              | 1           | 0          | 0          | I   |
| 8  | 0           |              | 0           | 1          | 0          | L   |
| 9  | 1           |              | 1           | 0          | 0          | I   |
| 10 | 0           |              | 0           | 1          | 1          | L   |
| 11 | 1           |              | 1           | 1          | 1          | 1   |
| 12 | 1           |              | 1           | 0          | 1          | L   |
| 13 | 0           |              | 0           | 0          | 1          | l   |
| 14 | 0           |              | 0           | 1          | 0          | l   |
| 15 | 1           |              | 1           | 0          | 1          | I   |
| 16 | 0           |              | 0           | 0          | 0          | I   |
| 17 | 0           |              | 0           | 0          | 1          | l   |
| 18 | 0           |              | 0           | 1          | 1          | l   |
| 19 | 1           |              | 1           | 1          | 0          | I   |
| 20 | 1           |              | 1           | 1          | 0          | I   |
| 21 | 1           |              | 1           | 1          | 1          | 1   |
| 22 | 1           |              | 1           | 0          | 0          | l   |
| 23 | 0           |              | 0           | 1          | 0          | I   |
| 24 | 1           |              | 1           | 0          | 0          | I   |
| 25 | 0           |              | 0           | 1          | 1          | I   |
| 26 | 1           |              | 1           | 1          | 1          | l   |
| 27 | 1           |              | 1           | 0          | 1          | I   |
| 28 | 0           |              | 0           | 0          | 1          | 1   |
| 29 | 0           |              | 0           | 1          | 0          | ١   |
| 30 | 1           |              | 1           | 0          | 1          | 1   |
| 31 | 0           |              | 0           | 0          | 0          | 1   |
| 32 | 0           |              | 0           | 0          | 1          | ١   |
| 33 | Ō           |              | 0           | 1          | 1          | 1   |
| 34 | 1           |              | 1           | 1          | 0          | 1   |
| 35 | 1           |              | 1           | 1          | 0          | 1   |
| 36 | 1           |              | 1           | 1          | 1          | 1   |
|    |             | <b>T</b> 1 T | DT          |            |            | 21  |

Figure 8. The Four RTDX Output Channels of the Transmitter and Receiver.

## V. CONCLUSION

In this work, both the downstream and upstream directions of the ADSL modem were modeled and simulated using MATLAB as well as implemented in a DSP platform using the C6713 floating point DSP. All the basic building blocks of the ADSL modem functionalities were implemented, tested and debugged using RTDX. A complete agreement between the transmitted and received data was obtained indicating the success of the implementation.

### References

- [1] Philip G., H. Dedieu and K. Jacobsen," Fundamentals of DSL Technology", Taylor & Francis Group, LLC, 2006.
- [2] ITU-T Recommendation G. 992.1, Asymmetric Digital Subscriber Line (ADSL) Transceivers, June 1999.
- [3] J. A. C. Bingham, "Multicarrier modulation for data transmission: an idea whose time has come," IEEE Communications Magazine, vol. 28, no. 5, pp. 5–14, 1990.
- [4] S. B. Weinstein and P. M. Ebert, "Data transmission by frequencydivision multiplexing using the discrete Fourier transform," IEEE Transactions on Communication Technology, vol. 19, no. 5, pp. 628– 634, 1971.

- [5] Danil J. Edeen, "Design, Implementation and Performance Evaluation of A new ADSL Link Aggregation Model", Ph.D. Thesis, University of Minnesota, May 2005.
- [6] Liang C. Chu," ADSL System Enhancement with Multiuser Detection ", Ph.D. Thesis, Georgia Institute of Technology, Atlanta Georgia, July 2001.
- [7] Miloš M., 'Maximizing Data Rate of Discrete Multitone Systems Using Time Domain Equalization Design ", Ph.D. Thesis, The University of Austin, May 2003.
- [8] S. Ravishankar, Padmaja K. V. and Uma B. V., "Implementation of Novel Bit-Loading Algorithm With Power Cut-Back in ADSL Transmitter on DSP", International Conference on Computation Intelligence and Multimedia Application, IEEE 2007, pp. 570-572.
- [9] Sobia Baig and N. D. Gohar," A Discrete Multitone Transceiver at the Heart of the PHY Layer of an In-Home Power Line Communication Local Area Network", IEEE Communication Magazine, April 2003, pp. 48-53.
- [10] Communications Toolbox 3 User's Guide 1996–2007 by The Math Works, Inc.
- [11] Steven A. Tretter," Communication System Design using DSP Algorithms with Laboratory Experiments for the TMS320C6713<sup>TM</sup> DSK", Springer Science + Business Media,LLC,2008.
- [12] W. Yu and J. M. Cioffi, "On Constant Power Water-Filling," IEEE ICC. 2001.
- [13] A. Leke and J. M. Cioffi. "A Maximum Rate Loading Algorithm for Discrete Multitone Modulation System," Proc. IEEE GLOBECOM '96, London, U.K., Nov. 1997. vol. 3. pp. 1514-1518.
- [14] G. Arslan, "Equalization for Discrete Multitone Transceivers", PhD. Thesis, University of Texas at Austin, December 2000.
- [15] S K Hasnain, Aresh D. Daruwalla and Ameer I. Saleem " A unified approach in Audio Signal Processing using the TMS320C6713 and Simulink Blocksets", IEEE 2009.
- [16] R. Chassaing and D. Reay," Digital Signal Processing and Application with the TMS320C6713 and TMS320C6416 DSK" Second Edition, John Wily & Sons, Inc., 2008.
- [17] Texas Instruments, TMS320C6713 Floating-Point Digital Signal Processor, SPRS186L – December 2001 – Revised November 2005.
  [18] Dominic Suryabudi," How to Begin Development Today with the
- [18] Dominic Suryabudi," How to Begin Development Today with the TMS320C6713 Floating-Point Digital Signal Processor", Texas Instruments, Application Report SPRA809a, October 2002.
- [19] Texas Instruments, Code Composer Studio IDE Getting Started Guide, User's Guide, SPRU509F-May 2005.